function doGet() {
  return HtmlService.createHtmlOutputFromFile('Index');
}

function saveData(name, date, duration, reason, remarks) {
  const sheet = SpreadsheetApp.getActiveSpreadsheet().getSheetByName('Submissions');
  sheet.appendRow([name, date, duration, reason, remarks]);
}

function getData() {
  const sheet = SpreadsheetApp.getActiveSpreadsheet().getSheetByName('Submissions');
  const data = sheet.getDataRange().getValues();
  
  // Convert date objects to strings and sort in reverse order
  const formattedData = data.map(row => {
    const [name, date, duration, reason, remarks] = row;
    return [name, formatDate(date), duration, reason, remarks];
  }).slice(1) // Remove header row
  .reverse(); // Reverse the order of rows

  return formattedData;
}

function formatDate(date) {
  if (date instanceof Date) {
    return Utilities.formatDate(date, Session.getScriptTimeZone(), 'yyyy-MM-dd');
  }
  return date; // In case it's already a string
}

function deleteRow(rowNumber) {
  const sheet = SpreadsheetApp.getActiveSpreadsheet().getSheetByName('Submissions');
  // Adjust rowNumber to account for header and reversed rows
  sheet.deleteRow(sheet.getLastRow() - rowNumber + 1);
}

function createMonthlySheet() {
  const ss = SpreadsheetApp.getActiveSpreadsheet();
  const currentDate = new Date();
  const monthAbbr = currentDate.toLocaleString('default', { month: 'short' }).slice(0, 2).toLowerCase(); // 'se' for September
  const yearLastDigit = currentDate.getFullYear().toString().slice(-1); // '4' for 2024
  const sequenceNumber = getLatestSequenceNumber(ss.getSheets().map(sheet => sheet.getName()), monthAbbr, yearLastDigit) + 1;

  const newSheetName = `${sequenceNumber}${monthAbbr}${yearLastDigit}`;

  // Create the new sheet if it doesn't already exist
  if (!ss.getSheets().map(sheet => sheet.getName()).includes(newSheetName)) {
    ss.insertSheet(newSheetName);
    const newSheet = ss.getSheetByName(newSheetName);
    
    // Optional: Add headers to the new sheet
    const headers = ['Name', 'Date', 'Duration', 'Reason', 'Remarks'];
    newSheet.getRange('A1:E1').setValues([headers]);
  }
}

function getLatestSequenceNumber(sheetNames, monthAbbr, yearLastDigit) {
  // Regex to match sheet names with the format: [number][monthAbbr][yearLastDigit]
  const pattern = new RegExp(`^(\\d+)${monthAbbr}${yearLastDigit}$`);
  let maxNumber = 0;
  
  for (const name of sheetNames) {
    const match = name.match(pattern);
    if (match) {
      const number = parseInt(match[1], 10);
      if (number > maxNumber) {
        maxNumber = number;
      }
    }
  }
  
  return maxNumber;
}
